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SYSTEM AND METHOD FOR 
SPEECH RECOGNITION AND TRANSCRIPTION 



RELATED APPLICATION 

The present patent application is related to co-pending U.S. Patent 
Application, Attorney Docket No^953.3-l, entitled "SYSTEM AND METHOD 
FOR MANAGEMENT OF TRANSCRIBED DOCUMENTS." 



TECHNICAL FIELD OF THE EWENTION 

The present invention relates to the field of speech recognition and 
transcription. 
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BACKGROUND OF THE INVENTION 

Speech recognition is a powerful tool for users to provide input to and 
interface with a computer. Because speech does not require the operation of 
cumbersome input tools such as a keyboard and pointing devices, it is the most 
convenient manner for issuing commands and instructions, as well as transforming 
fleeting thoughts and concepts into concrete expressions or words. This is an 
especially important input mechanism if the user is incapable of operating typical 
input tools because of impairment or inconvenience. In particular, users who are 
operating a moving vehicle can more safely use speech recognition to dial calls, check 
email messages, look up addresses and routes, dictate messages, etc. 

Some elementary speech recognition systems are capable of recognizing only 
a predetermined set of discrete words spoken in isolation, such as a set of commands 
or instructions used to operate a machine. Other speech recognition systems are able 
to identify and recognize particular words uttered in a continuous stream of words. 
Another class of speech recognition systems is capable of recognizing continuous 
speech that follows predetermined grammatical constraints. The most complex 
application of speech recognition is the recognition of all the words in continuous and 
spontaneous speech useful for transcribing dictation applications such as for dictating 
medical reports or legal documents. Such systems have a very large vocabulary and 
can be speaker-independent so that mandatory speaker training and enrollment is not 
necessary. 

Conventional speech recognition systems operate on recognizing phonemes, 
the smallest basic sound units that words are composed of, rather than words. The 
phonemes are then linked together to form words. The phoneme-based speech 
recognition is preferred in the prior art because very large amounts of random access 
memory is required to match words to sample words in the library, making it 
impracticable. 
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SUMMARY OF THE INVENTION 

In accordance with an embodiment of the present invention, a method for 
speech recognition includes the steps of receiving digital data representation of speech 
having at least one word, and searching a Hbrary containing digital data representation 
of a plurality of words and matching the digital data representation of the at least one 
word to digital data representation of a word in the library. The method further 
includes the steps of determining the number of syllables in the digital data 
representation of the at least one word, and then providing an ASCII representation of 
the matched word in response to the number of syllables of the at least one word 
being identical to the number of syllables of the matched word in the library. 

In accordance with another embodiment of the present invention, a method for 
speech recognition includes the steps of receiving digital waveform data 
representation of continuous speech having at least one word, and searching a library 
containing digital waveform data representation of a plurality of words and matching 
the digital waveform data representation of the at least one word to digital waveform 
data representation of a word in the library by matching at least waveform frequency, 
period and amplitude of the digital data representation of the at least one word to 
waveform frequency, period and amplitude of the digital waveform data 
representation of words in the library. The method ftirther includes the steps of 
determining the number of syllables in the digital data representation of the at least 
one word, and providing an ASCII representation of the matched word in the library 
in response to the number of syllables of the at least one word being identical to the 
number of syllables of the matched word in the library. 

In accordance with yet another embodiment of the present invention, a speech 
recognition system includes a digital representation of a user's spoken speech, and a 
waveform matching process operable to receive the digital speech representation and 
match the waveform characteristics to characteristics of model waveforms stored in a 
library. The matched model waveform each has an ASCII representation associated 
with each word in the spoken speech. The system fiirther includes a syllable 
matching process operable to receive the digital speech representation and determine 
the number of syllables in each word in the spoken speech and also verify the 
matched model waveform. A display screen is operable to display the ASCII 
representation of the matched model waveform. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

For a more complete understanding of the present invention, the objects and 
advantages thereof, reference is now made to the following descriptions taken in 
connection with the accompanying drawings in which: 

FIGURE I A to IC are a top-level block diagrams of embodiments of a speech 
recognition system; 

FIGURE 2 is a functional block diagram of an embodiment of the speech 
recognition system according to the teachings of the present invention; 

FIGURE 3 is a flowchart of an embodiment of the speech recognition process 
according to the teachings of the present invention; 

FIGURE 4 is a flowchart of an embodiment of the training process of the 
speech recognition system according to the teachings of the present invention; and 

FIGURES 5 A to 5C are time varying waveforms of the words "Hello Joshua" 
uttered by three different individuals of both sexes. 
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DETAILED DESCRIPTION OF THE DRAWINGS 

The preferred embodiment of the present invention and its advantages are best 
understood by referring to FIGURES 1 through 5 of the drawings, like numerals being 
used for like and corresponding parts of the various drawings. 

FIGURE lA is a top-level block diagram of one embodiment of a speech 
recognition system 10. As shown in FIGURE lA is a stand-alone speech recognition 
system 10, which includes a computer 11, such as a personal computer, workstation, 
laptop, notebook computer and the like. Suitable operating systems running on 
computer 11 may include WINDOWS, LINUX, NOVELL, etc. Other 
microprocessor-based devices, if equipped with sufficient computing power and 
speed, such as personal digital assistants, mobile phones, and other mobile or portable 
devices may also be considered as possible platforms for speech recognition system 
10. Computer 11 executes a speech recognition engine application 12 that performs 
the speech utterance-to-text transformation according to the teachings of the present 
invention. Computer 11 is fixrther equipped with a sound card 13, which is an 
expansion circuit board that enables a computer to receive, manipulate and output 
soimds. Speech and text data are stored in data structures such as data folders 14 in 
memory, such as random access memory (RAM), read-only memory (ROM), or other 
memory devices. Computer 11 is also equipped with a microphone 15 that is capable 
of receiving sound or spoken word input that is then provided to sound card 13 for 
processing. A local hard drive 16 may be also provided in computer 11 to store data 
associated with and used by speech recognition system 10 as well as speech 
recognition engine application itself Transcribed reports may be stored in local hard 
drive 16. User input devices of computer 1 1 may include a keyboard 17 and a mouse 
18. Hardcopy output devices of computer 11 may include a printer 19, facsimile 
machine, digital sender and other suitable devices. Not explicitly shown are speakers 
coupled to computer 11 for providing audio output fi-om system 10. Sound card 13 
enables computer 1 1 to output sound through the speakers connected to sound card 
13, to record soimd input firom microphone 15 connected to the computer, and to 
manipulate the data stored in data files and folders. Speech recognition system 10 is 
operable to recognize spoken words either received live firom microphone 15 via 
sound card 13 or fi-om sound files stored in data folders 14 or local hard drive 16. 
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As an example, a family of sound cards from CREATIVE LABS, such as the 
SOUND BLASTER LIVE! CT4830 and CT4810 are 16-bit sound cards that may be 
incorporated in speech recognition system 10. System 10 can also take advantage of 
future technology that may yield 16+ bit soxmd cards that will provide even better 
5 quality sound processing capabilities. Sound card 13 includes an analog-to-digital 

converter (ADC) circuit or chip (not explicitly shown) that is operable to convert the 
analog signal of sound waves received by microphone 15 into digital representation 
thereof. The analog-to-digital converter accomplishes this by sampling the analog 
signal and converting the spoken sound to waveform parameters such as pitch, 
10 volxmie, frequency, periods of silence, etc. Sound card 13 may also include sound 

conditioning circuits or devices that reduce or eliminate spurious and undesirable 
components from the signal. The digital speech data is then sent to a digital signal 

□ 

□ processor (DSP) (not explicitly shown) that processes the binary data according to a 

ill set of instructions stored on the sound card. The processed digital sound data is then 




^ 15 stored to a memory or storage device, such as memory, a hard disk, a CD ROM, etc. 

In the present invention, speech recognition system 10 includes software code that 
may receive the processed digital binary data from the sound card or from the storage 
device to perform the speech recognition function. 

^-efeiiillg to FIGURE H B. speech - rocopnition ^ystem 10 may ^e-Ji 
commimication, via a computer network 21 and an interface such as a hub OT^-^mtch 
hub 22, with a transcription management system (TMS) 23 operableje^anage the 
distribution and dissemination of the transcribed speech report^^^omputer network 
21 may be a global computer network such as the IntemeJ^imranet or extranet, and is 
used to transfer and receive data, commands andptiier information between speech 
25 recognition system 10 and transcriptiorj/management system 23. Suitable 

communication protocols such as the^Pile Transfer Protocol (FTP) may be used to 
transfer data between the two s^trais. Computer 1 1 may upload data to system 23 
using a dial-up modem, a o^le modem, an ISDN converter, or like devices (not 
explicitly shown). Thp^le transfer between systems 10 and 23 may initiated by 
30 either system to iml^d or download the data. Transcription management system 23 

includes a cpn^ter and suitable peripherals such as a central data storage 24 which 
house^-^iata related to various transcription report recipients, the manner in which the 



ripHon reports should be sent, and the transcription reports themsetvesr^ 
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srnptinn mgnngement R y R tem i k capable of Irans mittinfy the transcriptioT 
to the^ended recipients via various predetermined modes, suchasjeleetrSiSc mail, 
facsimile, OTs^a a secured web site, and is fiuther-Gf^abte'ofsending notifications via 
pager, email, fabsimile^^3jMl--otl^^ manners. Transcription management 

^ystem-^6nSTypIcally mxmnmm^ with multiple speech recognition systems 10 
Wiat^ifuim tlie speech-to-text "hMiction: • 

FIGURE IC is a simplifiied block diagram of a yet another embodiment of the 
speech recognition system. A network such as a local area network (LAN), wide area 
network (WAN) using a connection such as Category 5 cable, Tl, ISDN, dial-up 
connection, virtual private network (VPN), with a hub or switch hub 26 may be used 
to interconnect multiple speech recognition systems 10, 10", 10'" to facilitate file and 
data sharing. Any one or more of systems 10, 10", 10'" may be similarly configured 
to communicate with a transcription management system such as shown in FIGURE 
IB. 

FIGURE 2 is a functional block diagram of an embodiment of the speech 
recognition system according to the teachings of the present invention. The speech 
recognition system of the present invention is operable to convert continuous natural 
speech to text, where the speaker is not required to pause deliberately between words 
and does not need to adhere to a set of grammatical constraints. Digital binary data 
and digital representation of the speech waveform fi'om soimd card 13 is used as input 
to a training interface 36, waveform match process 38 and letter/syllable match 
process 40 of speech recognition system 10. During the training or speaker 
enrollment process, a user-specific waveform library 42 is built by storing the digital 
data associated with the received speech waveform of a particular speaker. 
Waveform match process 38 compares parameters such as wave amplitude, 
frequency, period, etc. of the user's speech waveform to model waveforms of known 
words stored in a library 44, If there is a match of the uttered waveform to a model 
waveform stored in library 44, then the word associated with the matched model 
waveform is provided as text output. However, the system of the present invention 
further improves the accuracy of speech recognition by allowing a personalized 
waveform library to be built firom training sessions and by further analyzing the 
uttered word's other characteristics, such as the nimiber of syllables in letter/syllable 
process 40. 
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Letter/syllable match process 40 also analyzes the uttered word if there was 
not a successful waveform match in process 38. The binary bit stream received from 
sound card 22 or obtained from sound file 28 is parsed and converted to ASCII 
representations of the letters in each word by consulting a binary/ ASCII table 48. The 
words are further analyzed to determine the number of syllables and used as another 
match criterion. Library 44 contains words that are searchable alphabetically, the 
number of syllables in each word, and notations indicating whether any word has been 
trained by particular users. Finally, the matched word is provided as text output on 
the screen, or executed as a command, such as new line, new paragraph, all caps, etc. 
Although word/syllable table 48 and user-specific waveform library 42 are shown in 
FIGURE 2 separately from library 44, either or both databases may be implemented 
as a part of library 44 for efficiency, speed, space and other considerations if so 
desired. 

Library 44 preferably contains corresponding speech waveforms and words 
that are commonly used by the particular user for a specific industry or field of use. 
For example, if the user is a radiologist and speech recognition system 10 is used to 
dictate and transcribe radiology or other medical reports, library 44 would contain 
additionally a vocabulary anticipatory of such use. On the other hand, if speech 
recognition system 10 will be used by attorneys in their legal practice, for example, 
library 44 would contain legal terminology that will be encoxmtered in its use. 

FIGURE 3 is a simplified flowchart of an embodiment of the speech 
recognition process 50 according to the teachings of the present invention. Speech 
input is received from sound card 13 or obtained from soimd file 28 in the form of a 
digitized waveform and a binary bit stream, as shown in block 52. The received 
digitized waveform is compared with the stored model waveforms in library 44, as 
shown in block 54. Waveform parameters such as amplitude, frequency, period, etc. 
are used in the comparison. A technique commonly called code excited linear 
prediction (CELP) may be used to perform the waveform matching function as known 
in the art. 

If a waveform match has been found, as a further assurance of accuracy, the 
waveform may be analyzed to determine the number of syllables in block 58. The 
syllable analysis process may be executed according to a confidence level rating or 
assessment of the waveform matching result. For example, if the confidence level is 
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high that the match is correct, then the syllable analysis process may not be necessary. 
In block 60, the number of syllables of the received speech waveform is used to verify 
the previously matched word in library 44. If the two words have the same number of 
syllables, then the matched word is provided as an output text, as shown in block 62. 

If there is no identical match in the matching process of block 56, a short list 
of words that are the closest match may be displayed on the screen to allow the user to 
select a word. The selection of a word would create an association of that word in 
library 44 or user-specific waveform library 42 with the received speech waveform. 
Currently known and future techniques to relate stored data elements may be used to 
correlate the speech waveform and the word in the library, such as using a relational 
database. 

If none of the displayed words is a match, then the digital binary stream is 
mapped to the ASCII representation of the word, character-by-character, by 
consulting a binary/ ASCII database 46, as shown in block 64. The digital data stream 
fi*om the sound card is parsed to extract the binary bits for each letter in the uttered 
word. The parsed binary bits are then used to look up in the binary/ ASCII table to 
determine the ASCII representation of each letter. The binary bit stream is thus 
transformed into a letter stream. The letter stream is then parsed according to 
boundaries between words, as shown in block 66. The word boundaries are 
characterized by binary bits that represent a space or silence between words. 

For example, for a 16-bit soimd card, each 16 bits of binary speech data output 
in the binary bit stream can be mapped to one ASCII character. However, in the 
present embodiment, only the meaningful least significant 8 bits, for example, out of 
16 bits are used to convert to the corresponding ASCII chciracter. In one embodiment, 
the binary bits "00100000" represent the space character in ASCII. As an example, 
the user speaks the words "Hello Joshua." When speech recognition system 10 
receives the binary bit stream firom the sound card or sound file, only a subset of bits, 
such as 8 bits, are needed firom each 16-bit group in the binary bit stream for speech 
recognition. Therefore, the received binary bit stream may be: 

01001000101100101 I 01 101 100 I 01 101 100 I 01 101 111 I 00100000 1 01001010 101101111 101110011 I 01101000 I 01110101 I 
01100001 
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where "|" is used herein to clearly demarcate the boundaries between the binary bit 
groups for the letters for increased clarity but does not represent a data output from 
the sound card. When binary/ ASCII table 46 is queried, the following binary to 
ASCn mapping is determined for the above bit stream: 



Binary Bits 


Character 


ASCII 


01001000 


H 


72 


01100101 


e 


101 


01101100 


1 


108 


01101100 


1 


108 


01101111 


o 


111 


00100000 


space 


32 


01001010 


J 


74 


01101111 


o 


111 


01110011 


s 


115 


01101000 


h 


104 


01110101 


u 


117 


01100001 


a 


97 



The Appendix is a table for the binary to ASCII mapping of the lower and upper cases 
of the alphabet and other commonly used symbols and numbers. Upper case letters 
are sometimes determined by grammar or syntax, such as a person's name, a city 
name, or at the beginning of a sentence, for example. Symbols such as " , ; : ! ? and # 
require the user to use a command, such as "open quotation" for inserting a " symbol. 

The received speech waveform is further analyzed to determine how many 
syllables are in each uttered word, as shown in block 68. It may be seen in the time 
varying waveforms of three individuals uttering the words "Hello Joshua" in 
FIGURES 5A-5C that the presence of each syllable can be easily identified and 
counted. The number of syllables along with the ASCII representation for the word is 
also used as a match characteristic or search index when a word/syllable table 48 is 
queried for a match, as shown in block 70. Although word/syllable table 48 is shown 
in FIGURE 2 as separate from library 44, library 44 may encompass the contents 
thereof to facilitate searching. Accordingly, the words may be arranged 
alphabetically and also according to the number of syllables in each word. An 
example of selected entries of the library is shown below: 
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Words 


Syllable 


Abbr. 


Library 

Train 

X I Mill 


User 


Main 
pntrv 


Key 


Command 


Hello 


2 

(h&- ' lO, 
he-) 








hel-lo 


* 




Centimeter 


4 

( ' sen-t&:- 
"mE-t&r 


cm 






cen-ti'me-ter 


* 




Reach 


1 (rEch) 




Reach 
(A) 


A,B 


reach 


*/** 




Axial 


3 

( * ak-sE- 

&i) 








ax*i*al 


* 




Millimeter 


4 

( * mi - 1 & - 
"mE-t&r) 


mm 


Millimeter 


B 


niiMi*me«ter 






w nat 


1 ( ' nwat: ; 








what 


* 




pancreas 


3 

' pa [ng] - 

krE-ficS 




Pancreas 

(A) 


A 


pan*cre*as 


•kjltit 




visceral 


'J 

('vi-s&- 
r&l) 




(C) 










AU-Caps- 
On 














Ucase 


All-Caps- 
Off 














Lease 


New 

Paragraph 














New 
Section 



The notations are defined as: meaning the particular word is in the library; "**" 
meaning the particular word already exists in the library but has been specifically 
trained by a particular user because of trouble with the recognition of that word in the 
existing library; "***" meaning the particular word is in the library but is designated 
as commands to be executed, not provided as output text. If more than one user has 
trained on a particular word, the corresponding user column entry would identify all 
the users. The correct waveform supplied by the current user is the one retrieved and 
used in waveform matching during speech recognition. It may be seen that the library 
entries for words commonly used in their abbreviated versions, such as 
centimeter/cm, millimeter/mm, include the respective abbreviations. The user may 
optionally select to output the abbreviations in the settings of the system whenever a 
word has an abbreviation in the library. 

If a match is found in block 72, then the matched word is provided as text 
output. If a sufficiently close or identical match cannot be found, then the user is 
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prompted to train the system to recognize that word, as shown in block 74. The user 
is prompted to spell out the word so that it may be stored in library 44 along with the 
digitized waveform and binary data stream of the word. Details of the training 
process are shown in a flowchart in FIGURE 4, 

FIGURE 4 is a flowchart of an embodiment of a training process 90 of the 
speech recognition system according to the teachings of the present invention. The 
training process may be entered into automatically and/or at the request of the user. 
For example, the user may issue a keyboard or verbal command to spell out a word, 
which directs speech recognition system 10 to enter into the training mode. The user 
is prompted to enter the word via a keyboard or by speaking the letters that make up 
the word, as shown in block 92, The received audio waveform of each uttered letter is 
then received and a determination of a letter representation is made for each utterance 
by waveform match process 38 (FIGURE 2), where the library contains model 
waveforms of the letters of the alphabet. The spelled-out word is then stored in 
association with the previously received speech waveform of the word in the library. 

During the speaker training or enrollment process, the digital speech data is 

also mapped to the ASCII representation of the word character-by-character by 

consulting a binary/ASCII database 46 (FIGURE 2), as shown in block 94. The 

digital data stream from the sound card is parsed to extract the binary bits for each 

letter in the uttered word. The parsed binary bits are then converted to the ASCII 

representation of each letter. The letter stream is then parsed according to boundaries 

between words. The word boundaries are characterized by binary bits that represent a 

space or silence between words. 

The-reeei ved sp ee ch w aveform-4^-^ rther anah^ed to dete rmme^ow-many 
Hbcg^ -^—"-^ ^ ^^^^^^ 

syllables are in the uttered word, as shown in block 96. As shownan-thgTime varying 
waveforms shown in FIGURES 5A-5C, a syllablei3..Gharacterized by a tight grouping 
of peaks exceeding a predeterminedapapKtuSe and separated from other syllables by 
waveforms having 2^ojx-''^r^^^\2iX amplitudes. Thus, the presence of each syllable 
canAe^^ff flsily id entified and the svUables counted^ 

The received word input, digitized waveform and the niraiber of syllables for 
the word are associated with one another and stored in library 44 (or in the 
appropriate database or tables), as shown in block 98. An appropriate notation is 
fiirther associated with the word to indicate that a particular user has provided user- 
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specific waveform for the particular word, as shown in block 100. The word is then 
provided as a text output onto the screen, as shown in block 102. The training process 
ends and returns in block 104 to the speech recognition process in FIGURE 3. Of 
course, the speech recognition process of FIGURES 3 and 4 continue until the 
dictation session is terminated by the user. 

It may be seen from the foregoing that speech recognition system 10 of the 
present invention uses several matching and analysis techniques to improve the 
accuracy of the system. The speech waveform is first analyzed and used to match 
model waveforms, then the binary digit data from the sound card is analyzed and 
mapped to ASCII if waveform matching is unsuccessful. The number of syllables in 
the words is also used as a further characteristic of the speech to determine a match. 
The user is involved to interact with the system to build a user-specific waveform 
library to further improve the accuracy of the system. Speech recognition 
performance is improved because digital binary matching is used. 

Speech recognition system 10 can be easily adapted to languages other than 
English. A binary conversion table for the target language instead of ASCII is needed 
to adapt system 10 to another language. Languages not based on an alphabet system 
cjan be adapted because the tone or waveform of the spoken words is used for 
matching. 

While the invention has been particularly shown and described by the 
foregoing detailed description, it will be understood by those skilled in the art that 
mutations, alterations, modifications, and various other changes in form and detail 
may be made without departing from the spirit and scope of the invention. 



